<template>
  <div class="detail-base">

    <t-row justify="start" v-if="detail_data.rule!=''">
      <t-col :span="12">
        <t-alert theme="error" :message="detail_data.rule" />
        <t-link  @click="loadHttpCopyMask">{{ $t('page.visit_log.detail.http_copy_mask') }}</t-link>
      </t-col>
    </t-row>
    <t-card :title="$t('page.visit_log.detail.ai.title')" class="container-base-margin-top">
      <t-space size="24px">
        <t-button theme="primary" @click="beforeSendAi">
          <logo-android-icon slot="icon" />
           {{ $t('page.visit_log.detail.ai.log_ai_analysis') }}
        </t-button>
      </t-space>
    </t-card>

    <t-card :title="$t('page.visit_log.detail.defense_status')" class="container-base-margin-top">
      <t-steps class="detail-base-info-steps" layout="horizontal" theme="dot" :current="3">
        <t-step-item :title="$t('page.visit_log.detail.visit_time')" :content="detail_data.create_time" />
        <t-step-item :title="$t('page.visit_log.detail.detection_time')" />
        <t-step-item :title="$t('page.visit_log.detail.defense_status_step')" :content="detail_data.action" />
        <t-step-item :title="$t('page.visit_log.detail.response_status')" :content="detail_data.status" />
      </t-steps>
    </t-card>
    <t-card :title="$t('common.details')" >
      <div class="info-block">
        <div class="info-item">
          <h1> {{ $t('page.visit_log.detail.request_identifier') }}</h1>
          <span>
            {{ detail_data.req_uuid }}
          </span>
        </div>
        <div class="info-item">
          <h1> {{ $t('page.visit_log.detail.request_time') }}</h1>
          <span>
            {{ detail_data.create_time }}
          </span>
        </div>
        <div class="info-item">
          <h1> {{ $t('page.visit_log.detail.request_domain') }}</h1>
          <span>
            {{ detail_data.host }}
          </span>
        </div>
        <div class="info-item">
          <h1> {{ $t('page.visit_log.detail.request_method') }}</h1>
          <span>
            {{ detail_data.method }}
          </span>
        </div>
        <div class="info-item">
          <h1> {{ $t('page.visit_log.detail.request_content_size') }}</h1>
          <span>
            {{ detail_data.content_length }}
          </span>
        </div>
        <div class="info-item">
          <h1> {{ $t('page.visit_log.detail.visitor_ip') }}</h1>
          <span>
            {{ detail_data.src_ip }}
            <t-button theme="primary" shape="round" size="small" @click="handleAddipblock(detail_data.src_ip)">{{ $t('page.visit_log.detail.add_to_deny_list') }}</t-button>

          </span>
        </div>
        <div class="info-item">
          <h1> {{ $t('page.visit_log.detail.visitor_port') }}</h1>
          <span>
            {{ detail_data.src_port }}
          </span>
        </div>
        <div class="info-item">
          <h1> {{ $t('page.visit_log.detail.request_region') }}</h1>
          <span>
            {{ detail_data.country }} {{ detail_data.province }} {{ detail_data.city }}
          </span>
        </div>
        <div class="info-item">
          <h1> {{ $t('page.visit_log.detail.response_code') }}</h1>
          <span>
            {{ detail_data.status_code }} ({{detail_data.status}} )
          </span>
        </div>
        <div class="info-item" v-if="detail_data.src_ip!=detail_data.net_src_ip" style="color: red">
          <!--实际ip-->
          <h1>  {{ $t('page.visit_log.detail.visitor_net_ip') }} </h1>
          <span>
              {{ detail_data.net_src_ip }}
              <t-button theme="primary" shape="round" size="small" @click="handleAddipblock(detail_data.net_src_ip)">{{ $t('page.visit_log.detail.add_to_deny_list') }}</t-button>

          </span>
        </div>
      </div>
    </t-card>
    <t-card :title="$t('page.visit_log.detail.more_info')" class="container-base-margin-top">
         <template #actions>
           <t-tooltip :content="$t('page.visit_log.detail.mouse_select_tooltip')">
               {{$t('page.visit_log.detail.quick_add_rule')}}:  <t-switch size="large" v-model="quickAddRuleChecked" :label="[$t('page.visit_log.detail.open'), $t('page.visit_log.detail.close')]"></t-switch>
               </t-tooltip>
        </template>
      <t-list :split="true">
        <t-list-item>
          <t-list-item-meta :title="$t('page.visit_log.detail.request_path')"></t-list-item-meta>
        </t-list-item>
         <t-textarea v-model="detail_data.url" :autosize="{ minRows: 3, maxRows: 5 }" readonly @blur="handleMouseSelect('url')"/>
        <t-list-item>
          <t-list-item-meta :title="$t('page.visit_log.detail.request_header')"></t-list-item-meta>
        </t-list-item>
         <t-textarea v-model="detail_data.header" :autosize="{ minRows: 3, maxRows: 5 }"  readonly @blur="handleMouseSelect('header')"/>
        <t-list-item>
         <t-list-item-meta :title="$t('page.visit_log.detail.request_user_browser')" ></t-list-item-meta>
        </t-list-item>
         <t-textarea v-model="detail_data.user_agent" :autosize="{ minRows: 3, maxRows: 5 }" readonly @blur="handleMouseSelect('user_agent')"/>
        <t-list-item>
          <t-list-item-meta :title="$t('page.visit_log.detail.request_cookies')" ></t-list-item-meta>
        </t-list-item>
         <t-textarea v-model="detail_data.cookies" :autosize="{ minRows: 3, maxRows: 5 }" readonly @blur="handleMouseSelect('cookies')"/>
        <t-list-item >
          <t-list-item-meta :title="$t('page.visit_log.detail.request_body')" ></t-list-item-meta>
        </t-list-item>
        <t-textarea v-model="detail_data.body" :autosize="{ minRows: 3, maxRows: 5 }" readonly @blur="handleMouseSelect('body')"/>
        <t-list-item >
          <t-list-item-meta :title="$t('page.visit_log.detail.request_form')" ></t-list-item-meta>
        </t-list-item>
        <t-textarea v-model="detail_data.post_form" :autosize="{ minRows: 3, maxRows: 5 }" readonly />
      </t-list>
    </t-card>
    <t-card :title="$t('page.visit_log.detail.response.response_title')">
      <t-list :split="true">
        <t-list-item>
          <t-list-item-meta :title="$t('page.visit_log.detail.response.response_header')"></t-list-item-meta>
        </t-list-item>
        <t-textarea v-model="detail_data.res_header" :autosize="{ minRows: 3, maxRows: 5 }" readonly />
        <t-list-item>
          <t-list-item-meta :title="$t('page.visit_log.detail.request_body')"></t-list-item-meta>
        </t-list-item>
        <t-textarea v-model="detail_data.res_body" :autosize="{ minRows: 3, maxRows: 5 }"  readonly />
        <t-list-item>
          <t-list-item-meta :title="$t('page.visit_log.detail.response_status')"></t-list-item-meta>
        </t-list-item>
        <span>
            {{ detail_data.status_code }} ({{detail_data.status}} )
        </span>
      </t-list>
    </t-card>
    <t-card :title="$t('page.visit_log.detail.time_cost.title')" >
      <div class="info-block">
        <div class="info-item">
          <h1> {{ $t('page.visit_log.detail.time_cost.pre_check_cost') }}</h1>
          <span>
            {{ detail_data.pre_check_cost }}ms
          </span>
        </div>
        <div class="info-item">
          <h1> {{ $t('page.visit_log.detail.time_cost.forward_cost') }}</h1>
          <span>
            {{ detail_data.forward_cost }}ms
          </span>
        </div>
        <div class="info-item">
          <h1> {{ $t('page.visit_log.detail.time_cost.backend_check_cost') }}</h1>
          <span>
            {{ detail_data.backend_check_cost }}ms
          </span>
        </div>
      </div>
    </t-card>

    <t-dialog :header="$t('page.visit_log.detail.http_copy_mask')"  :visible.sync="httpCopyMaskVisible"
              @confirm="()=>{httpCopyMaskVisible=false}"
              :onCancel="()=>{httpCopyMaskVisible=false}" >
      <t-alert theme="info" :message="$t('page.visit_log.detail.http_copy_mask_tip')" />
      <t-textarea v-model="httpCopyMask" :autosize="{ minRows: 5, maxRows: 10 }"  />
    </t-dialog>

    <t-dialog :header="$t('page.visit_log.detail.ai.before_send_ai')"  :visible.sync="httpAiMaskVisible"
              @confirm="handelToAi"
              :onCancel="()=>{httpAiMaskVisible=false}"  width="700px">
      <t-alert theme="info" :message="$t('page.visit_log.detail.ai.before_send_ai_tip')" />
      <t-textarea v-model="httpAiMask" :autosize="{ minRows: 5, maxRows: 10 }"  />
    </t-dialog>

  </div>
</template>
<script lang="ts">
  import {
    prefix
  } from '@/config/global';
  import { LogoAndroidIcon } from 'tdesign-icons-vue';

  import model from '@/service/service-detail-base';
  import {
    wafIPBlockAddApi
  } from '@/apis/ipblock';
  import { getHeaderCopyDetail ,geWebLogDetail} from '@/apis/waflog/attacklog';
  export default {
    name: 'WafAttackLogDetail',
    components:{
      LogoAndroidIcon
    },
    props:{
      prop_req_uuid:{
        type: String,
        default: ''
      },
      prop_current_db:{
        type: String,
        default: ''
      }
    },
    data() {
      return {
        prefix,
        baseInfoData: model.getBaseInfoData(),
        detail_data: {},
        quickAddRuleChecked:false,
        detail_req:{
          req_uuid:'',
          current_db:'',
        },
        httpCopyMask:'',
        httpCopyMaskVisible:false,
        httpAiMask:'',
        httpAiMaskVisible:false,
      };
    },
    beforeRouteUpdate(to, from) {
      console.log('beforeRouteUpdate')
    },
    mounted() {
      console.log('----mounted----')
      this.getDetail(this.$route.query.req_uuid);
    },
    beforeCreate() {
      console.log('----beforeCreate----')
    },
    created() {
      console.log('----created----')
    },
    beforeMount() {
      console.log('----beforeMount----')
    },
    beforeUpdate() {
      console.log('----beforeUpdate----')
    },
    updated() {
      console.log('----updated----')
    },
    watch: {
      '$route.query.req_uuid'(newVal, oldVal) {
        console.log('route.query.req_uuid changed', newVal, oldVal)
        if(newVal!=undefined){
          this.getDetail(newVal)
        }
      },
      prop_req_uuid(newVal, oldVal) {
        console.log('prop_req_uuid changed', newVal, oldVal)
        if(newVal!=undefined){
          this.getDetail(newVal)
        }
      },
    },
    methods: {
      handelToAi(){
        console.log("handelToAi",this.httpAiMask)
        this.$bus.$emit("sendAi",  this.httpAiMask)
        this.httpAiMaskVisible = false
      },
      beforeSendAi(){
        this.httpAiMask = ""
        getHeaderCopyDetail({
          REQ_UUID: this.detail_req.req_uuid,
          current_db_name:this.detail_req.current_db,
          output_format:"raw"
        })
          .then((res) => {
            let resdata = res
            console.log(resdata)
            if (resdata.code === 0) {
                this.httpAiMask = resdata.data
                this.httpAiMaskVisible = true
                // this.$bus.$emit("sendAi", resdata.data)
            }
          })
          .catch((e: Error) => {
            console.log(e);
          })
          .finally(() => {});
      },
      loadHttpCopyMask(){
        getHeaderCopyDetail({
            REQ_UUID: this.detail_req.req_uuid,
            current_db_name:this.detail_req.current_db,
            output_format:"curl"
        })
          .then((res) => {
            let resdata = res
            console.log(resdata)
            if (resdata.code === 0) {
              console.log("http mark",  resdata.data)
              this.httpCopyMask = resdata.data
              this.httpCopyMaskVisible = true
            }
          })
          .catch((e: Error) => {
            console.log(e);
          })
          .finally(() => {});
      },
      backPage(){
        　history.go(-1)
      },
      getDetail(uuid_and_name) {
        if(uuid_and_name == undefined){
          return
        }
        let arr =  uuid_and_name.split("#");
        let id = arr[0]
        let current_db_name = arr[1]

        this.detail_req.req_uuid = id
        this.detail_req.current_db = current_db_name
        let that = this
        geWebLogDetail({
              REQ_UUID: id,
              current_db_name:current_db_name
          })
          .then((res) => {
            let resdata = res
            console.log(resdata)
            if (resdata.code === 0) {
              that.detail_data = resdata.data;
            }
          })
          .catch((e: Error) => {
            console.log(e);
          })
          .finally(() => {});
      },
      handleAddipblock(ip) {

        if(this.detail_data.host_code==""){
          this.$message.warning("当前网站不存在");
          return
        }
        let that = this


        const confirmDia = this.$dialog.confirm({
                header: this.$t('page.visit_log.detail.add_to_deny_list_confirm_header')  ,
                body: this.$t('page.visit_log.detail.add_to_deny_list_confirm_body') ,
                confirmBtn: this.$t('common.confirm') ,
                cancelBtn: this.$t('common.cancel') ,
                onConfirm: ({ e }) => {
                   //add deny IP
                   let formData = {
                     host_code: this.detail_data.host_code,
                     ip: ip,
                     remarks: '手工增加',
                   };
                   wafIPBlockAddApi({
                       ...formData
                     })
                     .then((res) => {
                       let resdata = res
                       console.log(resdata)
                       if (resdata.code === 0) {
                         that.$message.success(resdata.msg);
                       } else {
                         that.$message.warning(resdata.msg);
                       }
                     })
                     .catch((e: Error) => {
                       console.log(e);
                     })
                     .finally(() => {});

                  confirmDia.destroy();
                },
                onClose: ({ e, trigger }) => {
                  console.log('e: ', e);
                  console.log('trigger: ', trigger);
                  confirmDia.hide();
                },
              });



      },
      handleMouseSelect(sourcePoint) {
         if(this.quickAddRuleChecked==false){
           return
         }
      		let text = window.getSelection().toString()
      		console.log(text)
          if(text.length==0){
            return
          }
          let that = this
          this.$router.push(
                  {
                    path:'/waf-host/wafruleedit',
                    query: {
                      type: "add",
                      host_code: that.detail_data.host_code,
                      contentstr:text,
                      is_manual_rule :1,
                      sourcePoint :sourcePoint
                    },
                  },
           );
      	}
    },
  };
</script>
<style lang="less" scoped>
  @import './index';
</style>
